草庐IT

Javascript onclick 函数传递 img src

全部标签

javascript - 在 JavaScript 中创建函数的不同方式

首先-是的,我知道有很多关于此的帖子,或者至少是非常相似的帖子。浏览过那些我仍然没有找到我正在寻找的答案:我了解到在javascript中创建函数有两种主要方法:vartest=function(a){console.log(a);}在运行时创建,并且:functiontest(a){console.log(a);}在运行前创建。今天我看到了这个:(functiontest(a){console.log(a);})();我以前从未见过。这个和上面两个有什么区别? 最佳答案 这是一个立即调用函数,它会在声明后立即调用自己。您可以阅读更

javascript - AngularJS 指令中的单元测试私有(private)函数

如何对在指令内定义的函数进行单元测试,如下面的myFunc?angular.module('myApp').directive('myDir',[function(){varmyFunc=function(arg){//codeinhere.};return{restrict:'A',scope:{},link:function(scope,element){}};}]);或者您如何定义我不想在指令之外公开的可测试指令特定函数? 最佳答案 最常见的方法是不测试私有(private)方法,而是测试公开其行为的公共(public)接口(

javascript - 一个可以进入任何方法链的函数

我喜欢Ruby的.tap方法的工作方式。它使您可以在不破坏链条的情况下利用任何方法链。我让您操作一个对象然后返回该对象,以便方法链可以正常进行。例如,如果你有foo="foobar".upcase.reverse,你可以这样做:"foo=foobar".upcase.tap{|s|prints}.reverse它将打印大写(但不反转)的字符串,并像原始行一样继续反转和赋值。我想在JS中有一个类似的功能,它只用于一个目的:将对象记录到控制台。我试过这个:Object.prototype.foo=function(){console.log(this);returnthis;};通常,它可

javascript - 获取分配给变量函数的名称

我正在尝试返回函数分配给的变量的名称。我在下面包含了一个示例。最终结果是我希望modelPerson.title()返回变量名title。例如我有以下代码:定义一些基本模型类型vartypes={string:function(){returnfunction(){return"Iwantthistoreturn'title'";}}};使用模型类型varmodelPerson={title:types.string(),firstName:types.string(),surname:types.string(),position:types.string()};正在尝试返回标题co

javascript - 从 chrome 扩展程序传递大 blob 或文件

我尝试编写一个扩展程序来缓存我网站上使用的一些大型媒体文件,以便您可以在安装扩展程序时在本地缓存这些文件:我通过chrome.runtime.sendMessage将URL传递给扩展(有效)在后台页面通过XMLHttpRequest获取媒体文件(有效)使用FileSystemAPI存储文件(有效)获取文件对象并使用URL.createObjectURL将其转换为URL(有效)返回网页的URL(错误)很遗憾,该网址无法在网页上使用。我收到以下错误:Notallowedtoloadlocalresource:blob:chrome-extension%3A//hlcoamoijhlmhjj

javascript - 你为什么要执行 $q.when() 而不给它传递一个 promise /值?

根据theAngulardocson$q,$q.when()期望传递一个promise/值。但我只是遇到了别人的代码,其中调用它时没有传递任何参数。这是我所看到的简化版本:varmodal=false;if(modalOpen){return$q.when()}modalOpen=true;modal=newModal({template:opts.template,});modal.result.finally(function(){modalOpen=false;});} 最佳答案 方法应该同步返回或异步返回以保持一致。如果一个

javascript - 将对象从 jade 传递到 angularjs 模板

我正在尝试将对象从Node传递到客户端,如下所示render:function(req,res){res.render('auth',{userData:req.session.user});}在我的auth.jade中,代码如下script.vardata=!{JSON.stringify(userData)}console.log(data)window.top.location='/profile'所以我将应用程序重定向到我在routeProvider中使用angularjs定义的新路由app.config(['$routeProvider','$locationProvider

javascript - 调用函数时 Angular ng-keyup 不起作用

我有这个代码:它不会调用搜索功能,因为如果我执行ng-click="search()"它会起作用。这是为什么? 最佳答案 ng-keyup对我来说非常好。有关示例,请参见此fiddle:http://jsfiddle.net/r74a5m25/代码:Hello:functionMyCtrl($scope,$log){$scope.search=function(){alert('test');};}确保您拥有最新版本的Angular以便使用ng-keyup。看起来它从版本1.0.8开始可用。

javascript - 为什么 ng-style 函数应用了两次?

我有一个像这样的Angular应用:angular.module('ngStyleApp',[]).controller('testCtrl',function($scope){$scope.list=[1,2,3];$scope.getStyles=function(index){console.log('gettingstylesforindex'+index);return{color:'red'};};});带有相应的标记:{{value}}正如预期的那样,可见输出是三个红色列表项。但是该语句总共被记录到控制台6次,这意味着View被渲染了两次:gettingstylesfor

javascript - 如果调用了 .bind() 函数,是否无法判断函数是否为生成器函数?

似乎在任何生成器函数上调用.bind(this)都会破坏我查看该函数是否为生成器的能力。关于如何解决此问题的任何想法?varisGenerator=function(fn){if(!fn){returnfalse;}varisGenerator=false;//Fastermethodfirst//Calling.bind(this)causesfn.constructor.nametobe'Function'if(fn.constructor.name==='GeneratorFunction'){isGenerator=true;}//Slowermethodsecond//Cal